/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package ui;

import io.PagoDTO;
import java.util.ArrayList;
import javax.swing.table.AbstractTableModel;

/**
 * Este es el modelo de tabla que se utiliza para las pagos, hereda de 
 * AbstractTableModel
 * @author nahuel
 */
public class PagosTableModel extends AbstractTableModel {

    /**
     * Encabezado de la tabla
     */
    String[] columnNames = {"Fecha de Pago", "Monto", "Observaciones"};
    /**
     * Lista de ventas a mostrar en la tabla
     */
    ArrayList<PagoDTO> data = new ArrayList<PagoDTO>();

    /**
     * Permite setear la lista de pagos de una cuota
     * @param data 
     */
    public void setData(ArrayList<PagoDTO> data) {
        this.data = data;
    }

    /**
     * Permite obtener un elemento indicando su posición en la tabla
     * @param posicion
     * @return 
     */
    public int getElementAt(int posicion) {
        return this.data.get(posicion).getId();
    }

    /**
     * Sobreescribimos este método para que se puedan editar los valores
     * que se encunetran en las celdas de la tabla mostrada en la pantalla
     * @param row numero de fila
     * @param column numero de columna
     * @return true si la celda se puede modificar, false en caso contrario
     */
    @Override
    public boolean isCellEditable(int row, int column) {
        // Aquí devolvemos true o false según queramos que una celda
        // identificada por fila,columna (row,column), sea o no editable
        return true;
    }

    /**
     * Este método se invoca luego de modificarse un valor en la tabla, modifica
     * el objeto y almacena el cambio en la base de datos
     * @param dato
     * @param fila
     * @param columna 
     */
    @Override
    public void setValueAt(Object dato, int fila, int columna) {
        PagoDTO pago = this.data.get(fila);
        switch (columna) {
            case 0:
                pago.setFechaPago(Fecha.obtenerFecha(dato.toString()));
                break;
            case 1:
                pago.setMontoPagado(Double.parseDouble(dato.toString()));
                break;
            case 2:
                pago.setObservaciones(dato.toString());
                break;
        }
        Ventana.getVentana().actualizarPagoBD(pago);
    }

    /**
     * Devuelve la cantidad de filas de la tabla
     * @return 
     */
    @Override
    public int getRowCount() {
        return this.data.size();
    }

    /**
     * Devuelve la cantidad de columnas de la tabla
     * @return 
     */
    @Override
    public int getColumnCount() {
        return this.columnNames.length;
    }

    /**
     * Devuelve el nombre de cada columna para utilizarse en el encabezado
     * @param col
     * @return 
     */
    @Override
    public String getColumnName(int col) {
        return columnNames[col].toString();
    }

    /**
     * De acuerdo a la posición en la tabla devuelve el objeto que debe ubicarse
     * alli cuando se dibuja la misma
     * @param rowIndex
     * @param columnIndex
     * @return 
     */
    @Override
    public Object getValueAt(int rowIndex, int columnIndex) {
        Object object = "";
        switch (columnIndex) {
            case 0:
                object = Fecha.formatearFecha(this.data.get(rowIndex).getFechaPago());
                break;
            case 1:
                object = this.data.get(rowIndex).getMontoPagado();
                break;
            case 2:
                object = this.data.get(rowIndex).getObservaciones();
                break;
        }
        return object;
    }
}
